package com.example.vaultmysql.repository;

import com.example.vaultmysql.entity.VaultConfig;
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.jpa.repository.Query;
import org.springframework.stereotype.Repository;

import java.util.List;
import java.util.Optional;

/**
 * Vault配置Repository
 * 
 * @author System
 * @version 1.0.0
 */
@Repository
public interface VaultConfigRepository extends JpaRepository<VaultConfig, String> {

    /**
     * 查找所有启用的Vault配置
     */
    List<VaultConfig> findByEnabledTrue();

    /**
     * 查找第一个启用的Vault配置
     */
    Optional<VaultConfig> findFirstByEnabledTrue();

    /**
     * 根据认证方法查找配置
     */
    List<VaultConfig> findByAuthMethodAndEnabledTrue(String authMethod);

    /**
     * 统计启用的配置数量
     */
    @Query("SELECT COUNT(v) FROM VaultConfig v WHERE v.enabled = true")
    Long countEnabledConfigs();
}